Zuul এর মাধ্যমে Routing এবং Filtering

Spring Cloud Zuul (Edge Server) - স্প্রিং ক্লাউড (Spring Cloud) - Java Technologies

289

Spring Cloud Zuul একটি রিভার্স প্রোক্সি সার্ভিস যা মাইক্রোসার্ভিসগুলির মধ্যে রাউটিং এবং ফিল্টারিং ব্যবস্থাপনা সহজ করে। এটি মূলত API গেটওয়ে হিসেবে কাজ করে, যেখানে ক্লায়েন্টদের HTTP রিকোয়েস্ট বিভিন্ন মাইক্রোসার্ভিসে রিডাইরেক্ট বা ফরওয়ার্ড করা হয়। Zuul-এর মাধ্যমে সার্ভিসগুলির মধ্যে লোড ব্যালেন্সিং, রাউটিং, অথেনটিকেশন, লগিং, ফিল্টারিং ইত্যাদি কার্যকরভাবে করা যায়।

এখানে Zuul এর মাধ্যমে Routing এবং Filtering কিভাবে করা যায় তা নিয়ে বিস্তারিত আলোচনা করা হবে।


Spring Cloud Zuul Configuration

Spring Cloud Zuul একটি API Gateway হিসেবে কাজ করে এবং এটি HTTP রিকোয়েস্ট গুলিকে সার্ভিসে রাউট করতে সাহায্য করে।

Zuul-এ Routing কনফিগারেশন

Zuul আপনাকে ক্লায়েন্ট রিকোয়েস্টকে নির্দিষ্ট সার্ভিসে রাউট করতে সাহায্য করে। একটি Zuul Server তৈরি করা হয় যা সব রিকোয়েস্টকে প্রয়োজনীয় সার্ভিসে রিডাইরেক্ট করে।


1. Zuul API Gateway Configuration

Maven Dependency (pom.xml)

Zuul ব্যবহার করতে হলে, আপনাকে spring-cloud-starter-zuul ডিপেনডেন্সি যোগ করতে হবে।

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>

Zuul Server Configuration (application.yml)

Zuul এর জন্য কনফিগারেশন করা হয় যেখানে আপনি রাউটিং লজিক এবং সার্ভিস URL নির্ধারণ করতে পারেন।

server:
  port: 8080

spring:
  application:
    name: zuul-server

zuul:
  routes:
    users-service: # 'users-service' will be routed to the below URI
      path: /users/** 
      url: http://localhost:8081
    orders-service:
      path: /orders/**
      url: http://localhost:8082
  • zuul.routes: এখানে আমরা users-service এবং orders-service এর জন্য রাউটিং কনফিগার করেছি।
  • path: রিকোয়েস্টের URL প্যাটার্ন। এই প্যাটার্নের সাথে মিলিয়ে রিকোয়েস্ট অন্য সার্ভিসে রাউট করা হবে।
  • url: লক্ষ্য সার্ভিসের URL।

2. Zuul Server Enablement

Zuul কে সক্রিয় করার জন্য @EnableZuulProxy অ্যানোটেশন ব্যবহার করতে হয়।

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

@SpringBootApplication
@EnableZuulProxy  // Enable Zuul proxy functionality
public class ZuulServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ZuulServerApplication.class, args);
    }
}

3. Client Services (User and Order Services)

Zuul API Gateway দিয়ে রাউট করা হবে এমন সার্ভিসের উদাহরণ:

User Service (user-service):

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class UserServiceApplication {

    public static void main(String[] args) {
        SpringApplication.run(UserServiceApplication.class, args);
    }

    @GetMapping("/users")
    public String getUsers() {
        return "Users from User Service";
    }
}

Order Service (order-service):

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class OrderServiceApplication {

    public static void main(String[] args) {
        SpringApplication.run(OrderServiceApplication.class, args);
    }

    @GetMapping("/orders")
    public String getOrders() {
        return "Orders from Order Service";
    }
}

Zuul Filtering

Zuul বিভিন্ন ধরনের ফিল্টার প্রদান করে যা রিকোয়েস্ট এবং রেসপন্স প্রক্রিয়া কাস্টমাইজ করার জন্য ব্যবহার করা যেতে পারে। Pre Filter, Route Filter, Post Filter, এবং Error Filter এই ৪টি প্রধান ফিল্টার টাইপ Zuul এ রয়েছে।


4. Pre Filter Example

Pre Filter রিকোয়েস্ট সার্ভিসে পৌঁছানোর আগেই প্রক্রিয়া করা হয়। এটি সাধারণত অথেনটিকেশন বা লগিংয়ের জন্য ব্যবহৃত হয়।

import com.netflix.zuul.ZuulFilter;
import org.springframework.stereotype.Component;

@Component
public class PreFilter extends ZuulFilter {

    @Override
    public String filterType() {
        return "pre"; // This filter will execute before the request is routed to the destination
    }

    @Override
    public int filterOrder() {
        return 1; // Filter order, lower value means higher priority
    }

    @Override
    public boolean shouldFilter() {
        return true; // Always apply this filter
    }

    @Override
    public Object run() {
        System.out.println("Pre Filter: Request is being processed.");
        return null; // Continue with the request processing
    }
}
  • filterType(): pre মানে রিকোয়েস্ট সার্ভিসে পৌঁছানোর আগে এটি রান করবে। আপনি route, post, বা error টাইপও ব্যবহার করতে পারেন।
  • shouldFilter(): ফিল্টারটি চালানো উচিত কিনা তা চেক করা হয়।
  • run(): ফিল্টারের কার্যকলাপ যেখানে আপনি লগিং বা অথেনটিকেশন করতে পারেন।

5. Post Filter Example

Post Filter রিকোয়েস্ট সার্ভিস থেকে রেসপন্স আসার পর এক্সিকিউট হয়। এটি লগিং বা রেসপন্স ট্রান্সফর্ম করতে ব্যবহার করা যেতে পারে।

import com.netflix.zuul.ZuulFilter;
import org.springframework.stereotype.Component;

@Component
public class PostFilter extends ZuulFilter {

    @Override
    public String filterType() {
        return "post"; // This filter will execute after the request is routed to the destination
    }

    @Override
    public int filterOrder() {
        return 1; // Filter order, higher value means lower priority
    }

    @Override
    public boolean shouldFilter() {
        return true; // Always apply this filter
    }

    @Override
    public Object run() {
        System.out.println("Post Filter: Response is being processed.");
        return null; // Continue with the response processing
    }
}

6. Error Filter Example

Error Filter তখন কার্যকর হয় যখন কোনো রিকোয়েস্টে ত্রুটি হয় এবং সার্ভিসে কোনো সমস্যা দেখা দেয়।

import com.netflix.zuul.ZuulFilter;
import org.springframework.stereotype.Component;

@Component
public class ErrorFilter extends ZuulFilter {

    @Override
    public String filterType() {
        return "error"; // This filter will execute in case of an error in the request processing
    }

    @Override
    public int filterOrder() {
        return 1; // Filter order
    }

    @Override
    public boolean shouldFilter() {
        return true; // Always apply this filter
    }

    @Override
    public Object run() {
        System.out.println("Error Filter: An error occurred during the request processing.");
        return null;
    }
}

Zuul Routing and Filtering Best Practices:

  1. Security: Zuul API Gateway ব্যবহার করার সময় নিরাপত্তা নিশ্চিত করুন, যেমন অথেনটিকেশন টোকেন যাচাই করা, ডোজ জিপ আক্রমণ প্রতিরোধ করা ইত্যাদি।
  2. Logging: প্রতিটি রিকোয়েস্টের জন্য লগিং কার্যকর করুন, যাতে পরে সহজে ট্রাবলশুটিং করা যায়।
  3. Error Handling: রাউটিং এবং ফিল্টারিং এ ত্রুটি পরিচালনা করার জন্য কাস্টম ErrorFilter ব্যবহার করুন।
  4. Load Balancing: Zuul এর মাধ্যমে লোড ব্যালেন্সিং এবং সার্ভিস ডিসকভারি কনফিগার করুন যাতে আপনার অ্যাপ্লিকেশন স্কেলেবল এবং রেসিলিয়েন্ট হয়।
  5. Filter Optimization: ফিল্টারগুলির কার্যকারিতা অপটিমাইজ করুন যাতে রিকোয়েস্ট/রেসপন্স প্রক্রিয়াগুলি দ্রুত এবং নির্ভরযোগ্য হয়।

উপসংহার:

Zuul API Gateway একটি অত্যন্ত কার্যকরী টুল যা routing এবং filtering ফিচার প্রদান করে। Zuul ব্যবহার করে আপনি সার্ভিসগুলির মধ্যে রাউটিং পরিচালনা করতে পারবেন এবং ফিল্টারিং এর মাধ্যমে রিকোয়েস্টের আগে বা পরে অনেক কাজ করতে পারবেন, যেমন অথেনটিকেশন, লগিং, বা ত্রুটি হ্যান্ডলিং। এটি আপনার মাইক্রোসার্ভিস আর্কিটেকচারকে আরও স্কেলেবল এবং সিকিউরড করতে সহায়ক।

Content added By
Promotion

Are you sure to start over?

Loading...